package thread.demo07.ExecutorService;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ThreadPoolDemo1 {
	public static void main(String[] args) {

		ExecutorService executorService = Executors.newFixedThreadPool(4);

		for (int i = 0; i < 10; i++) {
			int index = i;
			// submit(Runnable task)方法提交一个线程
			executorService.submit(() -> System.out.println("i:" + index + " executorService"));
		}
		executorService.shutdown();
	}
}

/**
 * 使用最新的“阿里巴巴编码规范插件”检测一下会提示：
 * <p>
 * 线程池不允许使用Executors去创建，而是通过ThreadPoolExecutor的方式，
 * 这样的处理方式让写的同学更加明确线程池的运行规则，规避资源耗尽的风险。 说明：Executors各个方法的弊端：
 * 
 * 1）newFixedThreadPool和newSingleThreadExecutor:
 * 主要问题是堆积的请求处理队列可能会耗费非常大的内存，甚至OOM。
 * 2）newCachedThreadPool和newScheduledThreadPool:
 * 主要问题是线程数最大数是Integer.MAX_VALUE，可能会创建数量非常多的线程，甚至OOM。
 */
